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SYSTEM AND METHOD FOR MONITORING 
AND ANALYZING THE EXECUTION OF 
COMPUTER PROGRAMS 

REFERENCE TO RELATED APPLICATION 

The present application claims priority benefit of Provi- 
sional Application No. 60/055,165, filed Jul. 31, 1997, the 
disclosure of which is incorporated herein by reference in its 
entirety. 

BACKGROUND OF THE INVENTION 

1. Field of the Invention 

The present invention relates to software tools for assist- 
ing software developers in the task of monitoring and 
analyzing the execution of computer programs, such as 
during the debugging process. 

2, Description of the Related Art 

Despite the significant diversity in software tracing and 
debugging programs ("debuggers'*), virtually all debuggers 
share a common operational model: the developer notices 
the presence of a bug during normal execution, and then uses 
the debugger to examine the program's behavior. The sec- 
ond part of this process is usually accomplished by setting 
a breakpoint near a possibly flawed section of code, and 
upon reaching the breakpoint, single -stepping forward 
through the section of code to evaluate the cause of the 
problem. 

Two significant problems arise in using this model. First, 
the developer needs to know in advance where the problem 
resides in order to set an appropriate breakpoint location. 
Setting such a breakpoint can be difficult when working with 
an event-driven system (such as the Microsoft Windows® 
operating system), because the developer does not always 
know which of the event handlers (callbacks) will be called. 

The second problem is that some bugs give rise to actual 
errors only during specific execution conditions, and these 
conditions cannot always be reproduced during the debug- 
ging process. For example, a program error that occurs 
during normal execution may not occur during execution 
under the debugger, since the debugger affects the execution 
of the program. This situation is analogous to the famous 
"Heizenberg effect" in physics: the tool that is used to 
analyze the phenomena actually changes its characteristics. 
The Heizenberg effect is especially apparent during the 
debugging of time -dependent applications, since these appli- 
cations rely on specific timing and synchronization condi- 
tions that are significantly altered when the program is 
executed step-by-step with the debugger. 

An example of this second type of problem is commonly 
encountered when software developers attempt to diagnose 
problems that have been identified by customers and other 
end users. Quite often, software problems appear for the first 
time at a customer's site. When trying to debug these 
problems at the development site (typically in response to a 
bug report), the developer often discovers that the problem 
cannot be reproduced. The reasons for this inability to 
reproduce the bug may range from an inaccurate description 
given by the customer, to a difference in environments such 
as files, memory size, system library versions, and configu- 
ration information. Distributed, client/server, and parallel 
systems, especially multi-threaded and multi-process 
systems, are notorious for having non-reproducible prob- 
lems because these systems depend heavily on timing and 
synchronization sequences that cannot easily be duplicated. 

When a bug cannot be reproduced at the development site, 
the developer normally cannot use a debugger, and generally 
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must resort to the tedious, and often unsuccessful, task of 
manually analyzing the source code. Alternatively, a mem- 
ber of the software development group can be sent to the 
customer site to debug the program on the computer system 

5 on which the bug was detected. Unfortunately, sending a 
developer to a customer's site is often prohibitively time 
consuming and expensive, and the process of setting up a 
debugging environment (source code files, compiler, 
debugger, etc.) at the customer site can be burdensome to the 

10 customer. 

Some software developers attempt to resolve the problem 
of monitoring the execution of an application by imbedding 
tracing code in the source code of the application. The 
imbedded tracing code is designed to provide information 

15 regarding the execution of the application. Often, this 
imbedded code is no more than code to print messages 
which are conditioned by some flag that can be enabled in 
response to a user request. Unfortunately, the imbedded code 
solution depends on inserting the tracing code into the 

20 source prior to ^ompiUng^and linking the shipped version bL 
the application. Tobe effective, the imbedded code must be 
placed logically near a bug in the source code so that the 
trace data will provide the necessary information. Trying to 
anticipate where a bug will occur is, in general, a futile task. 

25 Often there is no imbedded code where it is needed, and 
once the application has been shipped it is too late to add the 
desired code. 

Another drawback of current monitoring systems is the 
inability to correctly handle parallel execution, such as in a 

30 multiprocessor system. The monitoring systems mentioned 
above are designed for serial execution (single processor) 
architectures. Using serial techniques for parallel systems 
may cause several problems. First, the sampling activity 
done in the various parallel entities (threads or processes) 

35 may interfere with each other (e.g., the trace data produced 
by one entity may be over written by another entity). 
Second, the systems used to analyze the trace data cannot 
assume that the trace is sequential. For example, the function 
call graph in a serial environment is a simple tree. In a 

40 parallel processing environment, the function call graph is 
no longer a simple tree, but a collection of trees. There is a 
time-based relationship between each tree in the collection. 
Displaying the trace data as a separate calling tree for each 
entity is not appropriate, as this does not reveal when, during 

45 the execution, contexts switches were done between the 
various parallel entities. The location of the context switches 
in the execution sequence can be very important for debug- 
ging problems related to parallel processing. 

50 SUMMARY OF THE INVENTION 

The present invention overcomes these and other prob- 
lems associated with debugging and tracing the execution of 
computer programs. One aspect of the present invention is 
a software system that facilitates the process of identifying 

55 and isolating bugs within a client program by allowing a 
developer to trace the execution paths of the client. The 
tracing can be performed without requiring modifications to 
the executable or source code files of the client program. 
Preferably, the trace data collected during the tracing opera- 

60 tion is collected according to instructions in a trace control 
dataset, which is preferably stored in a Trace Control Infor- 
mation (TCI) file. Typically, the developer generates \hc TCI 
file by using a trace options editor., program, having a 
^graphical user interface. The options editor displays the 

65 client's source code representation on a display screen 
together with controls that allow the software developer to 
interactively specify the source code and data elements to be 
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traced. The options editor may use information created by a FIG. 3B is an illustration of a typical main frame window 

compiler or linker, such as debug information, in order to showing multiple threads. 

provide more information about the client and thereby make pj G 4 illustrates a process list window that lists the 

the process of selecting trace options easier. Once the trace processes to be traced 

options are selected, the client is run on a computer, and a 5 ___ _ .„ , . . , . t „ 

tracing library is used to attach to the memory image of the j FI p- 5 mustra , les th * tr * ce °P tlons alk > ws u a 
client (tHe client process), ^tracing library is configured, developer to select the functions to be traced and the 

to monitor execution of the client" and to collect trace data, information to be collected during the trace, 

based on selections in the trace options. The trace data FIG. 6 illustrates a file page window that provides a 

collected by the tracing library is written to an encoded hierarchical tree of trace objects listed according to hierar- 

buffer in memory. The data in the buffer may optionally be chical level. 

saved to a trace log file for later use. pig. 7 illustrates a class page window that provides a 

The developer then uses a trace analyzer program, also hierarchical tree of trace objects sorted by class, 

having a graphical user interface, to decode the trace infor- pj G g illustrates the process page window that provides 

mation into a human-readable form, again using the debug 35 a hierarchical tree that displays the traced process, and the 

information, and displays translated trace information on the threads for each process. 

display screen to allow the developer to analyze the execu- mQ „ iUustrates tne mnnm ^ window ^ Mov/s 

tion of the client program. In a preferred embodiment, the ^ ^ ^ ^ (o ^ ^ a ^ ^ ^ 

trace options editor and the trace analyzer are combined into _ . 

• , < , , m • c running, 

a single program called the analyzer. The analyzer is pref- on . n .„ ^ a . ^ _ . , . A „ 

li r j» j .1 t te w L„ 20 FIG. 10 illustrates the start process window that allows 

erably configured to run under the control of a multi -process *. t e 

trt ,n rt „ r ,u fl ^^,^i™ r tM( L mil i the user to load an executable file, attach to the loaded file, 

operating system and to allow the developer to trace mui- ,,01 j * ^ ! • iL 1 jjci 

** 1 *u j j n- 1 tt, f ku,™ ;^ execute the loaded file, and start tracing the loaded file, 

tiple threads and multiple processes. The tracing library is ' ^ 

preferably configured to run in the same process memory FIG. 11 shows a trace detai1 P*™ ^at displays a C++ class 

space as the client thereby tracing the execution of the client havin S ^erzl members and methods, a class derived from 

program without the need for context switches. mother classes, and classes as members of a class. 

In one embodiment, the software system provides a FIG. 12 illustrates a trace tree pane, showing a break (or 

remote mode that enables the client program to be traced at tear) in the trace tree where tracing was stopped and then 

a remote site, such as by the customer at a remote customer restarted. 

site, and then analyzed at the developer site. When the 30 FIG. 13 is a flowchart which illustrates the process of 

remote mode is used, the developer sends the TCI file for the attaching to (hooking) a running process, 

particular client to a remote user site together with a small FIG. 14 is a flowchart which illustrates the process of 

executable file called the tracing "agent." The agent is loading an executable file and attaching to (hooking) the 

adapted to be used at the remote user site as a stand-alone program. 

tracing component that enables a remote customer, who does 35 £ n tne drawings, like reference numbers are used to 

not have access to the source code of the client, to generate indicate like or functionally similar elements. In addition, 

a trace file that represents execution of the client application t he ^ digit or digits of each reference number generally 

at the remote site. The trace file is then sent to the developer indicate the figure number in which the referenced item first 

site (such as by email), and is analyzed by the software appears, 

developer using the analyzer. The remote mode thus enables 4Q 

the software developer to analyze how the client program is DETAILED DESCRIPTION OF THE 

operating at the remote site, without the need to visit the PREFERRED EMBODIMENT 

remote site, and without exposing to the customer the source ^ present inventkm provides a new mode i for tracing 

code or other confidential details of the client program. lne execution pam of and debugging a computer program. In 

The software system also preferably implements an online 45 mc preferred embodiment of the invention, this tracing 

mode that enables the software developer to interactively mo del is implemented within a set of tracing and debugging 

trace and analyze the execution of the client. When the too is that are collectively referred to as the BugTrapper 

software system is used in the online mode, the analyzer and system ("BugTrapper"). The BugTrapper tools are used to 

agent are effectively combined into one program that a monitor and analyze the execution of a computer program, 

developer can use to generate trace options, run and trace the 50 referred to as a client. One feature of the BugTrapper is that 

client, and display the trace results in near real-time on the i t does not req uire special instructions or commands to be 

display screen during execution of the client program. imbedded within the source code of the client, and it does 

BRIEF DESCRIPTION OF THE DRAWINGS n °t require any modifications to be made to the source or 

... , r 1( . P r executable files of the client. "Tracing," or "to trace," refers 

A software system which embodies the various features of js tQ ^ ^ Qf ^ a monitorin m to 

the invention will now be described with reference to the monito / and recc f rd i nformati on about the execution of the 

following drawings. client whUe th£ cHent fe mnning A « trace >. gene rally refers 

FIG. 1A is a block diagram illustrating the use of the (o ^ information recorded during tracing. Unlike conven- 

system to create a trace control information file. lional debuggers mat ^ breakpoints to stop the execution 

FIG. IB is a block diagram illustrating the use of the 60 0 f a client, the BugTrapper tools collect data while the cHent 

system in remote mode. is running- Using a process called "attaching", the BugTrap- 

FIG. 1C is a block diagram illustrating the use of the per tools instrument the client by inserting interrupt instruc- 

system to analyze a trace log file. tions at strategic points defined by the developer (such as 

FIG. 2 is a block diagram illustrating the use of the system function entry points) in the memory image of the client, 

in online mode. 65 This instrumentation process is analogous to the process of 

FIG. 3Ais an illustration of a typical main frame window connecting a logic analyzer to a circuit board by connecting 

provided by the system's trace analyzer module. probes to test points on the circuit board. When these 
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interrupts are triggered, the BugTrapper collects trace infor- 
mation about the client without the need for a context 
switch, and then allows the client to continue running. 

The BugTrapper implementations described herein oper- 
ate under, and are therefore disclosed in terms of, the 
Windows-NT and Windows-95 operating systems. It will be 
apparent, however, that the underlying techniques can be 
implemented using other operating systems that provide 
similar services. Other embodiments of the invention will be 
apparent from the following detailed description of the 
BugTrapper. 

Overview of BugTrapper System and User Model 

The BugTrapper provides two modes of use, remote mode 
and online mode. As discussed in more detail in the follow- 
ing text accompanying FIGS. 1A-1C, using remote mode a 
developer can trace the remote execution of a program that 
has been shipped to an end user (e.g. a customer or beta user) 
without providing a special version of the code to the user, 
and without visiting the user's site or exposing the source 
code level details of the program to the user. The system can 
also be used in an online mode wherein the developer can 
interactively trace a program and view the trace results in 
real time. 

Remote Mode 

Remote mode involves three basic steps shown in FIGS. 
1A through 1C. In step 1, shown in FIG. 1A, a developer 112 
uses a program called the BugTrapper analyzer 106 to create 
a file called a trace control information (TCI) file 120. The 
TCI file 120 contains instructions that specify what infor- 
mation is to be collected from a program to be traced (the 
client). The analyzer 106 obtains information about the 
client from a build (e.g., compile and link) by-product, such 
as a link map file, or, as in the preferred embodiment, a 
debug information file 121. Typically, the debug information 
file 112 will be created by a compiler and will contain 
information such as the names and addresses of software 
modules, call windows, etc. for the specific client. The 
developer 112 then sends the TCI file 120 and a small tracing 
application called the agent 104 to a user 110 as shown in 
FIG. IB. The user 110 runs the agent 104 and the client 102 
and instructs the agent 104 to attach to the client 102. The 
agent attaches to the client 102 by loading a client-side trace 
library 125 into the address space of the client 102. An 
agent-side trace library 124 is provided in the agent 104. The 
client-side trace library 125 and the agent-side trace library 

124 are referred to collectively as the "trace library." The 
agent-side trace library 124 and the client-side trace library 

125 exchange messages through normal interprocess com- 
munication mechanisms, and through a shared memory trace 
buffer 105. The agent-side trace library 124 uses information 
from the TCI file 102 to attach the client-side trace library 
125 into the client 102, and thereby obtain the trace infor- 
mation requested by the developer 112. 

The agent 104 and the client-side trace library 125 run in 
the same context so that the client 102 can signal the 
client-side trace library 125 without performing a context 
switch and thus without incurring the overhead of a context 
switch. For the purposes herein, a context can be a process, 
a thread, or any other unit of dispatch in a computer 
operating system. The client 102 can be any type of software 
module, including but not limited to, an application 
program, a device driver, or a dynamic link library (DLL), 
or a combination thereof. The client 102 can run in a single 
thread, or in multiple processes and/or multiple threads. 

In operation, the agent 104 attaches to the client 102 using 
a process known as "attaching." The agent 104 attaches to 
the client 102, either when the client 102 is being loaded or 



once the client 102 is running. Once attached, the agent 104 
extracts trace information, such as execution paths, subrou- 
tine calls, and variable usage, from the client 102. Again, the 
TCI file 120 contains instructions to the client-side trace 

s library 125 regarding the trace data to collect. /The^tra^^aUv 
< *eolleete~d!b^the^cti^ 125 is written tolhe 

trace buffer 105. On command from the user 110 (such as 
when a bug manifests itself), the agent 104 copies the 
contents of the trace buffer 105 to a trace log file 122. In 

10 some cases, the log data is written to a file automatically, 
such as when the client terminates. The user 110 sends the 
trace log file 122 back to the developer 112. As shown in 
FIG. 1C, the developer 112 then uses the analyzer 106 to 
view the information contained in the trace log file 122. 

15 When generating screen displays for the developer 112, the 
analyzer 106 obtains information from the debug informa- 
tion file 121. Since the analyzer 106 is used to create the TCI 
file 120 and to view the results in the trace log file 122, the 
developer can edit the TCI file 120 or create a new TCI file 

20 120 while viewing results from a trace log file 122. 

Remote mode is used primarily to provide support to 
users 110 that are located remotely relative to the developer 
112. In remote mode, the agent 104 is provided to the user 
110 as a stand-alone component that enables the user to 

25 generate a trace log file that represents the execution of the 
client. The TCI file 120 and the trace log file 122 both may 
contain data that discloses secrets about the internal opera- 
tion of the client 102 and thus both files are written using an 
encoded format that is not readily decipherable by the user 

30 110. Thus, in providing the TCI file 120 and the agent 104 
to the user, the developer 112 is not divulging information to 
the user that would readily divulge secrets about the client 
102 or help the user 110 in an attempt to reverse engineer the 
client 102. The Agent traces the client without any need for 

35 modification of the client. The developer 112 does not need 
to build a special version of the client 102 executable file and 
send it to the customer, neither does the customer need to 
pre-process the client executable file before tracing. From 
the perspective of the remote user, the agent 104 acts 

40 essentially as a black box that records the execution path of 
the client 102. As explained above, the trace itself is not 
displayed on the screen, but immediately after the bug 
reoccurs in the application, the user 110 can dump the trace 
data to the trace log file 122 and send this file to the 

45 developer 112 (such as by email) for analysis. The developer 
112 then uses the analyzer 106 to view the trace log file 
created by the user 110 and identify the problematic execu- 
tion sequence. In remote mode, the user 110 does not need 
access to the source code or the debug information. The 

50 agent 104, the TCI file 120, and the trace log file 122 are 
preferably small enough to be sent via email between the 
developer 112 and the user 110. Further details regarding the 
remote mode of operation are provided in the sections 
below. 

55 Online Mode 

As shown in FIG. 2, the BugTrapper may also be used in 
an online mode rather than remote mode as shown in the 
previous figures. In this mode, the BugTrapper is used by the 
developer 112 to locally analyze a client 102, which will 

60 typically be a program that is still being developed. For 
example, the online mode can be used as an aid during the 
development as a preliminary or complementary step to 
using a conventional debugger. In many cases it is hard to 
tell exactly where a bug resides and, therefore, where 

65 breakpoints should be inserted. Online mode provides the 
proper basis for setting these breakpoints. Later, if further 
analysis is required, a more conventional debugger can be 
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used. In online mode, the analyzer 106 is used to perform all 
of its normal operations (e.g. creating the TCI file 120 and 
viewing the trace results) as well as the operations per- 
formed by the agent 104 in remote mode. Thus, in online 
mode, the agent 104 is not used because it is not needed. The 
developer 112 uses the analyzer 106 to run the client 102 and 
attach the client-side trace library 125 to the client 102. In 
online mode, the analyzer 106 reads the trace buffer 105 in 
near real-time to provide near real-time analysis function- 
ality. In the online mode, the analyzer 106 immediately 
displays the trace information to the developer 112. 

The developer 112 uses the analyzer 106 to interactively 
create trace control information (TCI). The TCI may be sent 
to the client-side trace library 125 via file input/output 
operations or through conventional inter-process communi- 
cation mechanisms such as shared memory, message passing 
or remote procedure calls. The TCI indicates to the client- 
side trace library 125 what portions of the client 102 to trace, 
and when the tracing is to be performed. As the client 
program 102 runs, the client-side trace library 125 collects 
the trace information and relays the information back to the 
analyzer 106, which displays the information in near real- 
time within one or more windows of the BugTrapper. 

Operational Overview of the Tracing Function 

Regardless of which operational mode is used (online or 
remote), the client 102 is run in conjunction with the 
client-side trace library 125. As described in detail below, 
the client-side trace library 125 is attached to the in-memory 
image of the client 102 and generates trace information that 
describes the execution of the client 102. The Td file 120, 
provided by the developer 112, specifies where tracing is to 
take place and what information will be stored. Because the 
client is traced without the need for context switches, the 
effect of this tracing operation on the performance of the 
client 102 is minimal, so that even time -dependent bugs can 
be reliably diagnosed. As described below, this process does 
not require any modification to the source or object code 
files of the client 102, and can therefore be used with a client 
102 that was not designed to be traced or debugged. 

The analyzer 106 is used to analyze the trace data and 
isolate the bug. The developer 112 may either analyze the 
trace data as it is generated (online mode), or the developer 
112 may analyze trace data stored in the trace log file 122 
(mainly remote mode). As described below, the assembly 
level information in the trace log file is converted back to a 
source level format using the same debug information used 
to create the TCI file 120. During the trace analysis process, 
the analyzer 106 provides the developer 112 with execution 
analysis options that are similar to those of conventional 
debuggers, including options for single stepping and running 
forward through the traced execution of the client 102 while 
monitoring program variables. In addition, the analyzer 106 
allows the developer 112 to step backward in the trace, and 
to search for breakpoints both in the future and in the past. 

The attaching mechanism used to attach the client -side 
trace library 125 to the client 102 involves replacing selected 
object code instructions (or fields of such instructions) of the 
memory image of the client 102 with interrupt (INT) instruc- 
tions to create trace points. The locations of the interrupts are 
specified by the TCI file 122 that is created for the specific 
client 102. When such an interrupt instruction is executed, a 
branch occurs to the tracing library 125. The client-side trace 
library 125 logs the event of passing the trace point location 
and captures pre-specified state information, such as values 
of specific program variables and microprocessor registers. 
The instructions that are replaced by the interrupt instruc- 
tions are maintained within a separate data structure to 
preserve the functionality of the application. 
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Overview of the Analyzer User Interface 

The analyzer 106 comprises a User Interface module that 
reads trace data, either from the trace buffer 105 (during 
on-line mode tracing) or from the trace log file 122 (e.g. after 

S remote tracing) and displays the data in a format, such as a 
trace tree, that shows the sequence of traced events that have 
occurred during execution of the client 102. Much of the 
trace data comprises assembly addresses. With reference to 
FIG. 1C, the analyzer 106 uses the debug information 121 to 

io translate the traced assembly addresses to comprehensive 
strings that are meaningful to the developer. In order to save 
memory and gain performance, this translation to strings is 
preferably done only for the portion of the trace data which 
is displayed at any given time, not the whole database of 

15 trace data. Thus, for example, in formatting a screen display 
in the user interface, only the trace data needed for the 
display in the user interface at any given time is read from 
the log file 122. This allows the analyzer 106 to display data 
from a trace log file 122 with more than a million trace 

20 records. 

The debug information 121 is preferably created by a 
compiler when the client is compiled. Using the debug 
information 121 the analyzer translates function names and 
source lines to addresses when creating the TCI file 120. 

25 Conversely, the analyzer 106 uses the debug information 
121 to translate addresses in the trace data back into function 
names and source lines when formatting a display for the 
user interface. One skilled in the art will recognize that other 
build information may be used as well, including, for 

30 example, information in a linker map file and the Type 
Library information available in a Microsoft OLE-compliant 
executable. 

Preferably, the debug information is never used by the 
trace libraries 124, 125 or the agent 102, but only by the 

35 analyzer 106. This is desirable for speed because debug 
information access is typically relatively slow. This is also 
desirable for security since there is no need to send to the 
user 110 any symbolic information that might disclose 
confidential information about the client 102. 

40 ^ejiaTmlv/Zer^lO^ttallQWSjrthe vdevelopery 1*12 to> .open 
multiple; trace tree windows and define a different filter 
(.trace control instructions) for each of window. When read- 
ing a trace record, each window filter is preferably examined 
separately to see if the record should be displayed. The filters 

45 from the various windows are combined in order to create 
the TCI file 120, which is read by the client-side trace library 
125. In other words, the multiple windows with different 
filters are handled by the User Interface, and the client-side 
trace library 125 reads from a single TCI file 120. 

50 FIG. 3Ais an illustration of a typical frame window 300 
provided by the analyzer 106. The analyzer frame window 
300 displays similar information both when performing 
online tracing (online mode) and when displaying a trace log 
file (remote mode). The frame window 300 is a split frame 

55 having four panes. The panes include a trace tree pane 310, 
an "executable" pane 314, a trace detail pane 316, and a 
source pane 318. The analyzer frame 300 further provides a 
menu bar 304, a dockable toolbar 306, and a status bar 312. 
The menu bar 304 provides drop -down menus labeled 

60 "File," "Edit," "View," "Executable," and "Help." The trace 
tree pane 310 contains a thread caption bar 320, described 
below in connection with the Analyzer. Below the thread 
caption bar 320 is a trace tree 330. The trace tree 330 is a 
hierarchical tree control that graphically displays the current 

65 trace information for the execution thread indicated in the 
thread caption bar 320. The trace tree 330 displays, in a 
hierarchical tree graph, the sequence of function calls and 
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returns (the dynamic call tree) in the executable programs 
(collectively the client 102) listed in the executable pane 
314. Traced source lines also appear in the trace tree, 
between the call and return of the function in which the lines 
are located. FIG. 3 illustrates a single thread header and 
thread tree combination (the items 320 and 330). However, 
multiple thread captions and thread tree combinations will 
be displayed when there are context switches between 
multiple threads or processes. 

The executable pane 314 displays an "executable" listbox 
361. Each line in the executable listbox 361 displays infor- 
mation about an executable image that is currently being 
traced. Each line in the list box 361 displays a filename field 
360, a process id (PID) field 362, and a status field 364. 
Typical values for the status field 364 include "running," 
"inactive," and "exited." The trace detail pane 316 contains 
a trace detail tree 350, which that is preferably implemented 
as a conventional hierarchical tree control. The trace detail 
tree 350 displays attributes, variables such as arguments in 
a function call window, and function return values of a 
function selected in the trace tree 330. The source pane 318 
displays a source listing of one of the files listed in the source 
listbox 361. The source listing displayed in the source pane 
318 corresponds to the source code of the function selected 
in the trace tree 330 or to the selected source line. The source 
code is automatically scrolled to the location of the selected 
function. 

The frame window 300 also contains a title bar which 
displays the name of the analyzer 106 and a file name of a 
log or Trace Control Information (TCI) file that is currently 
open. If the current file has not yet been saved, the string 
"-New" is concatenated to the file name display. 

The status bar 312 displays the status of the analyzer 106 
(e.g. Ready), the source code file containing the source code 
listed in the source code pane 318, and the line and column 
number of a current line in the source pane 318. 

The toolbar 306 provides windows tooltips and the but- 
tons listed in Table 1. 



10 



TABLE 1 -continued 



Buttons on the toolbar 306 



Button 



Menu 
Equivalent 



Key Description 



"Add" 



10 



"Run" 



Executable | 
Add 



Executable | 
Run 



Ins 



F5 



15 



20 



"Attach" 



25 



"Terminate" 



"Options" 



Executable | 
Attach 



Executable | 
Terminate 

Executable | 
Trace Options 



Adds an executable to the Exe- 
cutable pane, without running it, 
so that it can be run and traced 
at a later date. 

When the <New Executable> 
string is selected, adds an execu- 
table to the Executable pane, 
starts this executable and 
begins tracing. When an execu- 
table which is not running is 
selected in the Executable 
pane, starts this executable and 
begins tracing. 

When the <New Executable* 
string is selected, attaches a 
running executable to the Execu- 
table pane and begins tracing. 
When an executable that is not 
traced is selected, attaches the 
running process of this execu- 
table, if it exists. 
Terminates the executable 
currently selected in the 
Executable pane. 
Opens the Trace Options 
window in which you can spec- 
ify the elements that you want to 
trace for the selected executable. 



30 



35 



Using the Analyzer to Create the TQ File 

The TCI file 120 specifies one or more clients 102 and the 
specific elements (functions, processes and so on) to be 
traced either in online or remote mode. The TCI information 
is specified in a trace options window (described in the text 
associated with FIG. 5). The TCI file 120 is used to save 
trace control information so that the same trace options can 
be used at a later time and to send trace control information 



to a user 110 to trace the client 102. The subsections that 
FIG. 3B shows a typical frame window 300 with multiple 40 follow provide a general overview of selecting trace infor- 



threads in the trace tree pane 310. FIG. 3B shows a separate 
trace tree for each thread and a thread caption bar (similar to 
the thread caption bar 320 shown in FIG. 3A) for each 
thread. 

TABLE 1 

Buttons on the toolbar 306 



Button 



Menu 
Equivalent 



Key 



Description 



"Open'* File | Open Ctrl +- 0 Opens an existing Trace Control 

Information file. 

"Save" File | Save Ctrl + S Saves the current Trace Control 

Information to a file. 

"Clear" Edit | Clear All Clears the Trace Tree pane, 

the Trace Detail pane, and the 
Source pane. 

"Find" Edit | Find Ctrl + F Finds a specific string in the 

executable source code or trace 
tree. 

"Bookmark" Edit | Book- Adds or deletes a bookmark for 

mark the currently selected function, 

or edits the name of an 
existing bookmark. 
"Window" Mew | New Opens a new instance of the 

Window analyzer. 
"Start/Stop" Executable | Starts or stops tracing the execu- 

Start/Stop tables listed in the Executable 

Trace pane. 



mation for a TCI file 120 and descriptions of various trace 
options, different ways to access the trace options, and how 
to use the trace options to specify elements to be traced. 
The TCI file 120 for a client 102 is interactively generated 
45 by the software developer 112 using the analyzer 106. 
During this process, the analyzer 106 displays the source 
structure (modules, directories, source files, C++ classes, 
functions, etc.) of the client 102 using the source code debug 
information 121 generated by the compiler during compi- 
50 lation of the client 102. As is well known in the art, such 
debug information 121 may be in an open format (as with a 
COFF structure), or proprietary format (such as the 
Microsoft PDB format), and can be accessed using an 
appropriate application program interface (API). Using the 
55 analyzer 106, the developer 112 selects the functions and 
source code lines to be traced. This information is then 
translated into addresses and instructions that are recorded 
within the TCI file. In other embodiments of the invention, 
trace points may be added to the memory image of the client 
60 102 by scanning the image's object code "on the fly" for 
specific types of object code instructions to be replaced. 

Trace control information is defined for a specific client 
102. In order to access the trace tool, the developer 112 first 
adds the desired programs 110 to the list of executables 
65 shown in the executable pane 314 shown in FIG. 3. The 
executable is preferably compiled in a manner such that 
debug information is available. In many development 
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environments, debug information may be included in an 
optimized "release" build such that creation of the debug 
information does not affect the optimization. In a preferred 
embodiment, the debug information is stored in a PDB file. 
If during an attempt to add the executable to the Executable 
pane 314 a PDB file is not found by the analyzer 106, the 
developer 112 is prompted to specify the location of the PDB 
file. Once an executable has been added to the Executable 
pane 314, the developer 112 can set the trace control 
information using the available trace options described 
below. 

To use the online mode to trace an executable 314 that is 
not currently running, the developer selects an executable 
file to run as the client 102. To run an executable file, the 
developer 112 double-clicks the <New Executable> text 365 
in the executable pane 314 to open a file selection window 
thus allowing the developer 112 to select the required 
executable. Alternatively, the developer 112 can click the 
Run button on the toolbar 306, or select the Run option from 
the "Executable" menu after selecting the <New Execut- 
able> text. The file selection window provides a command 
line arguments text box to allow the developer 112 to specify 
command line arguments for the selected executable file. 

After selecting an executable to be a client 102 a trace 
options window (as described below in connection with 
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information that reflects the execution of the client 102 and 
sends the trace information to the analyzer 106 for display. 

The developer can also add an executable file (e.g. a 
windows .exe file) to the executable pane 314 without 
actually running the executable file. To add an executable 
that is not currently running (and which is not to be run yet) 
to the executable pane 314, the developer 112 selects the 
<New Executable> text 365 and then clicks the Add button 
on the toolbar 306, whereupon a file selection window is 
displayed. The developer 112 uses the file selection window 
to select the desired executable and closes the file selection 
window. The file selection window provides a text field to 
allow the developer to enter command line arguments for the 
executable. Upon closing the file selection window, the trace 
options window 500 is displayed which enables the devel- 
oper 112 to select the functions to trace. After selecting trace 
options and closing the trace options window, the selected 
executable is inserted into the Executable pane 314 with the 
status "Inactive/' The developer can then begin a trace on 
the inactive executable by selecting the executable in the 
executable pane 314 and clicking the "Run" or "Attach" 
buttons on the toolbar 306. 

In a preferred embodiment, the developer 112 can only 
create a new TCI file 120 when the executable list 361 
contains the names of one or more executable files. To create 



FIG. 5.) is displayed which allows the developer 112 to 25 a TCI file 120, the developer 112 selects "Save" from the 

specify which functions to trace. After selecting the desired "File" menu. The developer can also open a previously 

trace options and closing the trace options window, the saved TCI file 120 and then modify the TCI file 120 using 

executable starts running and BugTrapper starts tracing. As the trace options window 500. Once a TCI file 120 has been 

the client 102 runs, trace data is collected and the trace data created (or opened) the developer 112 can select an execut- 

are immediately displayed in the analyzer frame window 30 able from the executable pane and click the "Run" or 

300 as shown in FIG. 3. "Attach" button from the toolbar to start tracing. 

To cause the analyzer 106 to trace an executable that is p IG 5 illustrates the trace options window 500. The trace 

currently running, the developer 112 may click the "Attach" options window 500 is divided into two panes, a filter tree 

button on the toolbar 306 after selecting the <New Execut- pane 50 i an d a source code pane 504. The filter tree pane 

able> text. Upon clicking the "Attach" button on the toolbar 35 501 is a multi-page pane having four pages: a file page 602 

306, a process list window 400 is displayed, as shown in . 
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FIG. 4. The process list window 400 displays either an 
applications list 402 or a process list (not shown). One 
skilled in the art will understand that, according to the 
Windows operating system, an application is a process that 
is attached to a top level window. The applications list 402 
displays a list of all of the applications that are currently 
running. The process list window 400 also provides a 
process list, which is a list of the processes that are currently 
running. The applications list 402 is selected for display by 
an applications list tab and the process list is selected for 45 
display by pressing the applications list tab. To select a 
process from the process list window, the developer 112 
clicks the Applications tab or the Processes tab as required, 
and then selects the application or process to be traced. The 
process list window 400 also provides a refresh button to 
refresh the application fist and the process list, and an OK 
button to close the process list window 400. 

After the developer 112 selects an application or process 
using the process list window 400, and closes the process list 
window 400, the analyzer 106 displays a trace options 
window 500, as shown in FIG. 6 below. The application or 
process selected in the process list window 400 becomes the 
client 102. The analyzer 106 can display trace data for 
multiple processes and applications (multiple clients); 
however, for the sake of simplicity, the operation of the 
analyzer 106 is described below primarily in terms of a 
single client 102. The trace options window 500 allows the 
developer 112 to select the functions to be traced. Selecting 
trace options is described below in the text in connection 
with FIG. 5. After selecting trace options and closing the 
trace options window 500, the client-side trace library 125 
is attached to the client 102, and the client 102 continues to 
run. The client-side trace library 125 thereafter collects trace 



which is selected by a file tab 510; a class page 702 which 
is selected by a class tab 512; a name page 502 which is 
selected by a name tab 514; and a process page 802 which 
is selected by a process tab 516. The name page 502 is 
shown in FIG. 5. The file page 602 is shown in FIG. 6, the 
class page 702 is shown in FIG. 7, and the process page 802 
is shown in FIG. 8. The trace options window also provides 
an "advanced" button 520 and an "add DLL" button 522. 

The trace options window 500 allows the developer 112 
to specify which functions to trace and what to display in the 
trace tree 330. The trace options window 502 allows the 
developer 112 to filter out functions which have already 
been traced. These functions will be redisplayed where they 
were traced if they are later re-select for tracing. If a function 
is not selected for tracing in the trace options window 500, 
it will not be displayed in the trace tree 330. If a function that 
was not traced is filtered in again, it will not appear in that 
portion of the information that has already been displayed. 
For example, consider the following C++ program: 



fi(){} 

K(){} 
main ( ) { 

while (1) { 

getchar (c); 

} 

} 
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Using the above program as an example of a client 102, and 
assuming that the user forms the following steps: 
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1. Select the functions fl, f2, and main for tracing in the 
trace options window 500. 

2. Execute one loop and view the resulting trace. 

3. Deselect (filter out) f2 for tracing in the Trace Options 
window 500. 

4. Execute the loop again. 

5. Re-select (filter in) f2 for tracing in the Trace Options 
window. 

6. Execute the loop once more. 

Then, after Step 4 the following depicts the elements that 

are displayed in the trace window, with the symbol 

representing a tear in the trace as described below in 
connection with FIG. 12. 



main 
fl 



(Step 3) 

fl 

After Step 6 the trace appears as follows: 

main 

fl 

f2 



fl 

fl 

£2 



■ (Step 4) 
- (Step 5) 
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In the above example, after f2 was filtered in again in step 
5, it was restored in the first portion of the trace because 
filtering out occurred after this portion had already been 
executed. However, f2 never returned to the second portion, 
which was executed after f2 had been filtered out. Therefore, 
changing the trace options also determines which of the 
functions that have already been traced will be displayed. If 
a traced function is then filtered out from the trace, it can 
later be filtered in again. 

In the filter tree pane 501, the process tab 516, corre- 
sponding to the process page 802, is not displayed prior to 
activating a process. Each of the four pages in the filter tree 
pane 501 displays a tree that the developer 112 can use to 
select the functions to be traced and analyzed. The source 
code pane 504 displays a source code fragment that contains 
the source code for the selected function and enables the 
developer 112 to select the specific source fines to be traced. 
Each line of executable source in the source code pane 504 
is provided with a check box displayed along the left edge 
of the pane 504. The developer 112 checks the box to select 
the corresponding source line for tracing. 

The "advanced" button 520 opens a window which allows 
the developer 112 to specify which elements to display 
during the trace (e.g. arguments, pointers, "this" class mem- 
bers and return values) and the maximum string length to be 
traced. The add DLL button 522 opens a window which 
allows the developer 112 to specify DLL files to be traced. 
This is useful when a DLL is loaded dynamically, as 
described below. 

The developer 112 uses the filter tree pane 501 to select 
functions to be traced. Four page selection tabs at the top of 
the filter tree pane 501 enable the developer 112 to view the 
functions classified (sorted) according to file (on the file 
page 602), class (on the class page 702), name (on the name 
page 502) or process (on the process page 802). The way the 
functions are organized is different for each classification 
tab. However, the tree structure that is displayed in each of 
the four pages operates in the same way, even though the 
data elements in the tree are different for each page. Thus, 



the following discussion relating to the filter tree applies to 
any of the four pages of the filter tree pane 502. 

The filter tree is a tree of function names with check boxes 
to the left of each name. Function check boxes appear blank, 
checked or dimmed as follows: 

Blank: No sub-element of this branch is checked. 
Checked: All sub-elements of this branch are checked. 
Dimmed: Some (but not all) sub-elements of this branch 
are checked. 

The developer 112 uses the check boxes to selected the 
functions to trace and then closes the trace options window 
by clicking an OK button. 

The file page 602, shown in FIG. 6, provides a hierarchi- 
cal tree that lists the objects according to their hierarchical 
level in the following order: 
The Process that is traced. 

The executable and DLL files which comprise the pro- 
cess. 
Static Libraries 
Source file directories. 
Source files residing in these directories. 
Classes contained in each source file and functions in each 

source file that do not belong to any class. 
Functions belonging to the classes. 
The source file structure is taken from the debug infor- 
mation (e.g., .PDB) files 121 for the client 102. If the full 
path name of the source file is not contained in the .PDB file, 
then the functions contained in that source file are located in 
separate branch of the trace tree 330 under the title 
<Unknown Directory>. Functions that are included in 
the .PDB file, but whose source file is unknown, are located 
in a separate branch of the trace tree 330 under the title 
<Unknown Source File>. 

The class page 702, shown in FIG. 7, provides a hierar- 
chical tree that lists the trace objects sorted by class, 
ignoring their distribution amongst source files. Functions, 
which do not belong to a specific class are located in a 
separate branch of the trace tree 330 under the title <Func- 
tions>. The name page 502, shown in FIG. 5, provides a 
hierarchical tree that lists functions sorted alphabetically by 
name. Leading underscores and class names for methods are 
ignored. The process page 802, shown in FIG. 8, provides a 
hierarchical tree that displays each process that has been 
selected for tracing. Under each process is a list of the 
threads for that process. 

DLL files that are not linked with the executable but rather 
are loaded dynamically (e.g. libraries loaded using the 
LoadLibrary system call), are not shown by default in the 
50 trace options window 500. In order to trace a dynamically 
loaded DLL file, the dynamically loaded DLL file should be 
added to the list of DLL files using the Add DLL button 522 
in the Trace Options window 500. Clicking the add DLL 
button 522 displays a file selection window. Using the file 
55 selection window, the developer 112 then selects the 
required DLL file. The selected DLL file is added to the filter 
tree in the filter tree pane 502 of the trace options window 
500. 

The BugTrapper can also trace DLL files loaded by an 
60 executable, even when the executable does not contain 
debug information. For example, if the developer 112 writes 
a DLL file as an add-on (e.g., an ActiveX control) to a 
commercial program (e.g. Microsoft Internet Explorer), the 
developer 112 can activate BugTrapper on the commercial 
program and perform a trace on the add-on. 

The BugTrapper also allows the developer 112 to specify 
various function attributes to be displayed in the trace detail 
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pane 316 of the analyzer frame window 300, (shown in FIG. 
3) while performing a trace. The developer 112 can choose 
to display arguments, pointers, "this" class members and 
return values. One skilled in the art will recognize that under 
the terminology of C++, a "this" class member is a class 
member that is referenced by the C++ "this" pointer. The 
developer 112 can also specify the maximum string length to 
be displayed. Selecting more options generally reduces the 
number of records in the trace log file and thus reduces the 
amount of execution time that is logged. The discussion 
below regarding the cyclic trace buffer provides further 
details of how much execution time is actually logged. The 
advanced button provides access to an advanced options 
window (not shown). 

Selecting the arguments checkbox causes function argu- 
ments to be displayed in the trace detail pane 316. Selecting 
the "pointers" checkbox causes data to which a first level 
function argument of the pointer type points to be displayed. 
In other words, selecting the pointers checkbox causes 
function arguments that are pointers to be de-referenced for 
the display. The developer 112 may select the "this" check- 
box to have "this" to have all members in a class displayed 
in the trace detail pane 316 when there is a call to a method 
which has a this pointer. The developer 112 may select the 
return checkbox to have function return values displayed in 
the trace detail pane 316. 

The BugTrapper also allows the developer 112 to control 
tracing of specific source lines. In the source code pane 504, 
a checkbox is located to the left of each executable source 
line, which can be traced. To view the source code fragment 
containing a specific function, the developer 112 selects the 
required function in the filter tree pane 502 and the analyzer 
106 displays the appropriate source code fragment in the 
source code pane 504. If analyzer cannot locate the source 
code, then the source code is not displayed and the developer 
112 may press the spacebar or right-click in the source code 
pane 504 and select a "Source Location" command from a 
pop-up menu. The "Source Location" command opens a 
dialog box which allows the developer 112 to specify a 
source code file to be displayed in the source code pane 504. 
The appropriate source code is then displayed in the source 
code pane 504, as shown in FIG. 5. 

To select the source code lines to trace, the developer 
clicks the check boxes corresponding to the desired lines. To 
select multiple lines, the developer 112 can either press 
CTRL+A to select the whole source code file, or drag the 
mouse along several lines and thereby select a group of 
lines. The developer 112 can then click on any checkbox in 
the selected area to check all the selected lines or click on a 
checkbox that is already checked to deselect all selected the 
lines. If lines of code in a file are selected for tracing, then 
the filename is displayed in blue. The developer 112 may 
also select which variables (e.g., local variables, global 
variables, static variables, etc.) should be traced for each 
traced line. 

If a client 102 is modified and recompiled, it may not be 
desirable to use an existing TCI file for that client 102 (for 
example, ajjfunction^thatwwaSrSelected for* tracing may have- 
been from the modified and recompiled version). Whenever 
the BugTrapper encounters an outdated TCI file 122, it 
issues a warning and then continues to trace based on a 
heuristic algorithm, which attempts to match the trace 
instructions to the modified client executable. Trace infor- 
mation for an application that may be recompiled at some 
future date can be supplemented by saving the trace infor- 
mation to an Extended Trace Control Information (TCE) file 
rather than a regular TCI file 120. The TCE file contains 
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extra symbolic information (such as function names) that is 
not part of a regular TCI file 120. Using the extra symbolic 
information greatly increases the chances that the heuristic 
trace algorithm will produce the desired results. It is espe- 
cially desirable to use a TCE file at the user 102 site when 
the client 102 is frequently modified, and the developer 112 
does not want to redefine the trace options after each 
compilation. The TCE file is identified by a .TCE extension. 

The developer may save a TCI file 120 by clicking the 
save button on the toolbar 306, whereupon the trace control 
information is saved. The first time that information is saved 
to a new TCI file 120, a file selection window appears. In the 
file selection window, the developer 112 may select the type 
of file (TCI or TCE) in a "Save as" type box. 

The TCI file 120 can be used to trace a local client 102 at 
a later time, or it can be sent to a user 110 for use with the 
agent 104 to trace a client 102 at a remote site. In a preferred 
embodiment, for remote tracing, the developer 112 sends the 
user 110 a self -extracting zip file that contains the agent 104 
and the TCI file 120. Using the Agent As described above, 
the agent 104 is an executable module which the developer 
112 can provide to a user 110 along with a Trace Control 
Information (TCI) file in order to trace a client 102. The 
trace data collected by the agent 104 are written to the trace 
log file 122 which the user sends to the developer 112. The 
developer 112 uses the analyzer 106 to view the contents of 
the trace log file and analyze the trace information in the log 
file 122, Trace analysis using the analyzer 106 is discussed 
in subsequent sections of this disclosure. The present section 
discusses the procedures for starting the agent 104, includ- 
ing the first step performed by the user 110 to run the agent 
104. The present section also discloses techniques for select- 
ing the TCI file 120, specifying a directory for the trace log 
file 122, specifying the client 102, and, finally, using the 
agent 104 to control the logging of trace data. The agent 104 
is an easy- to -run standalone application, with step-by-step 
instructions provided on the screen. To trace an application, 
the user 102 needs both the agent 104 and the TCI file 120. 
The TCI file 120 is prepared, as described above, by the 
developer 112 and contains information about the client 102 
and the specific functions to be traced. 

In a preferred embodiment, the developer supplies the 
agent 104 as a self extracting zip file that can be installed by 
simply double clicking on the zip file name. At the end of the 
installation, the user 110 can launch the agent 102. When the 
agent 102 is launched, it displays a TCI select window (not 
shown) which is a conventional file select dialog that allows 
the user to select the TCI file 120. Likewise, the agent 104 
provides a log file window, which allows the user 110 to 
select a directory for the log file 122. The default log file is 
the last log file that was opened by the agent 104. The next 
step in using the agent 104 is to specify the client 102 
executable(s) to trace. 

If an executable specified in the TCI file 120 is already 
running, an attach to running processes window (running 
window) 900 is displayed, as shown in FIG. 9. The running 
window 900 provides a finish button 902, a cancel button 
904, a back button 906, and a list of processes 908. The list 
of processes 908 shows any currently running processes that 
are specified in the TCI file 120. The list of processes 908 
shows all processes that are specified in the TCI file 120 that 
are not currently running as disabled (grayed). The running 
window 900 allows the user 102 to select a currently running 
process to trace by selecting items in the list 908. Preferably, 
the user 110 will deselect any executables that are to be 
re -run from the start (that is, when the user does not want to 
attach to an executable that is already running). To select a 
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running process, the user 110 selects a process from the list 
908, and then presses the finish button 902 to cause the 
BugTrapper to attach to the client processes and starts to 
collect trace data. 

If an executable specified in the TCI file is not currently 
running, then a start processes window (start window) 1000 
is displayed, as shown in FIG. 10,. The start window 1000 
provides a finish button 1002, a cancel button 1004, a back 
button 1006, and a list of executable files 1010. The start 
window 1000 also provides a path field 1012, a parameters 
field 1014, and a directory field 1016. The list of files 1010 
shows any currently running processes that are specified in 
the TCI file. The start window 1000 allows the user to 
specify executables that are not currently running to be 
traced. The agent 104 will run the selected client(s) 102 and 
trace them according to the information in the TCI file 120. 

The file list 1010 displays the executables, which are 
listed in the TCI file. Each item in the file list 1010 is 
provided with a check box. To specify the executables to 
run, the user 102 checks the boxes for the desired 
executables in the file list 1010. If the file path in the file list 
1010 is not correct, then the user may enter the correct file 
path in the path field 1012. The user 110 may also add 
command line arguments in the parameters field 1014. The 
file path and command line steps may be repeated as needed 
to specify the file path and commands for additional 
executables. When the finish button 1002 is clicked, an agent 
window (described below) is displayed and the agent 104 
runs the specified executables, attaches to the executable 
processes, and starts tracing. 

The agent window (not shown) is displayed by the agent 
104. The agent window displays the names of the TCI file 
and the log file. The agent window also contains an animated 
icon whose movement indicates whether trace data is cur- 
rently being collected while the client 102 is running. The 
agent window also contains: a "Start/Stop" button to start or 
stop the trace; a "Clear" button to clear the trace buffer 105, 
a "Dump" button to save the contents of trace buffer 105 to 
the log file; and an "Exit" button to exit the agent 104. 

The "Stop/Start" button allows the user 110 to stop and 
restart tracing when desired. Stopping the trace may 
improve system performance. The "Start/Stop" button 
toggles between Stop and Start according to the tracing 
status. The animated icon moves when tracing is in progress. 
The "Clear" button allows the user 110 to clear the trace 
buffer 105. The cleared information is not stored in the log 
file 122 unless the user first uses the dump button. The dump 
button allows the user 110 to save the contents of the trace 
buffer 105 to the log file 122. On the first save after a new 
process had been started, the agent 104 overwrites the old 
log file 122 (if one exists). On subsequent saves, new 
information will be appended to the existing log file 122. 
Clicking the exit button causes the agent 104 to exit. Upon 
exiting, the trace buffer is written to the log file. Note that the 
trace information is written to the log file when either dump 
or exit is clicked and also when the traced application 
crashes or terminates. The user 110 will preferably use the 
dump button frequently if it appears likely that the entire 
operating system may crash. 

In one embodiment, the user may select to write every 
trace line to the disk as it is traced, or, the user may select 
to write trace lines periodically every N seconds. Such 
writing is useful, for example, when it appears likely that the 
entire operating system may crash. 
Analysis of the Trace Information 

The analyzer 106 is used to analyze a trace, either online 
as an application runs or off-line using a remote trace log. 
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The general topics that fall under the rubric of trace analysis 
include, starting an online trace, opening a previously saved 
trace log file, viewing trace information, interpreting the 
trace information, working with trace information, and addi- 
tional trace functions that are available when performing an 
online trace. 

The BugTrapper allows the developer 112 to trace a client 
102 executable in order to pinpoint an element in the client 
102 code that causes a bug. The primary device for display- 
ing trace information in the analyzer 106 is the trace tree 330 
in the trace tree pane 310 shown in FIG. 3, The trace control 
information (TCI) filters can be modified during trace analy- 
sis to filter out some of the available trace data according to 
the needs of the developer 112. 

Analysis of a remote trace (or a previously saved online 
trace) is started by opening a previously saved trace log file 
and displaying the trace information that it contains in the 
trace tree pane 310. The log file 122 may either have been 
created by saving trace information using the analyzer 106, 
or the log file 122 may have been created at a remote 
location using the agent 104. A trace log file 122 is opened 
by using an "Open Log" command from the "File" pull 
down menu found on the menu bar 304. Once a trace log file 
122 is open, the title bar 302 displays the name and path of 
the opened log file 122. Once a trace log file 122 is open, the 
developer can view the trace information using various 
panes in the analyzer frame window 300. Trace information 
is displayed in the trace tree pane 310, the trace detail pane 
316, and the source pane 318. 

The trace tree 330, in the trace tree pane 310, is a 
hierarchical tree showing trace data collected from the client 
102. Trace data includes information about events that took 
place during execution of the client 102, including function 
calls, function returns, selected source lines, etc. The devel- 
oper 112 can use the mouse to choose any function from the 
trace tree, whereupon the arguments and return values for 
the chosen function are shown in the trace detail pane 316, 
and the source for the chosen function is displayed in the 
source pane 318. The types of trace information displayed 
for both online traces and a trace from log files is almost 
identical, however the log file trace provides a static display, 
while the online trace is dynamic and can be viewed as the 
trace information is being collected. 

The trace tree 330 displays a hierarchical tree of the 
sequence of function calls and returns in the client 102. The 
number of lines in the trace tree is shown in the trace tree 
pane title bar 308. The trace tree 330 is organized in a 
standard tree structure and the developer 112 can click on the 
tree control buttons to collapse or expand the view of 
functions belonging to lower hierarchical levels. Clicking on 
a function or a source line in the trace tree pane 310 causes 
the trace detail pane 316 and the source pane 318 to change 
to display information relevant to the function. Selecting a 
function in the trace tree 330 and pressing the delete button 
on the keyboard removes the selected function from the 
trace. This is equivalent to filtering the function out of the 
trace. 

The trace data is written to a buffer in memory called the 
trace buffer 105, and from there either displayed in the trace 
tree pane 310 (when performing an online trace) or written 
to a log file (when performing a remote trace). The trace 
buffer 105 is organized as a circular buffer of fixed size. The 
size of the trace buffer 105 can be set by the developer 112. 
When the trace buffer 105 is full, new trace records over- 
write the oldest records contained in the buffer 105. One 
skilled in the art will recognize that other buffering methods 
can be used without changing the scope of the present 
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invention. For example, the trace information could be The trace detail pane 316 shows available details describ - 

stored in a buffer, which simply added trace records without ing the function selected in the trace tree view. FIG. 11 

overwriting old records. In a preferred embodiment, loss of shows a trace detail pane 1116 that displays a C++ class 

old data is acceptable because, when the client 102 having several members and methods, a class derived from 

malfunctions, the developer 112 is usually interested in the s another classes, and classes as members of a class. The trace 

most recent records prior to the malfunction. Thus, there is details are displayed in a trace detail tree 350 which is a 

usually little need to keep all of the records, especially the hierarchical tree structure. A right arrow 351 in the trace 

oldest ones. The size of the trace buffer 105 is set so that it delai] n6 marks wfacre the is caUcd A left 

will be big enough to hold a large number of records vvithout am)W at ^ boUom of ^ ^ tree ^ mafks wfaere the 

40 n 00cT S 'ri Tk reSOUrCeS * TyP1CaUy ' 20,000 10 io function returned to its caller. Some of the data that can be 

WhenTe trac^buffer 105 is written to a log file 122, the ^P 1 ^ ( su /* a * the «B"™*0 « ^ Splayed if an 

trace records are preferably appended to the end of the log °P tlon 15 . sel u ecte( * m * e ad ™ ced . trace °P' lons - If aa 

file 122. In a log file, old records are not deleted, and the argument m the call window of a function is of ^the aggregate 

trace size is limited only by the available disk space. tv P e >. th L e argument's components will be displayed beneath 

Alternatively, when tracing online, the trace tree is actu- 15 lhe n e nt arrow 351 ia the form of a hierarchy tree. If an 

ally an image of the trace buffer 105. Because of this, the argument is of the pointer type, and pointers were selected 

trace tree will not display more records than the trace buffer in the advanced trace options, then the value displayed in the 

105 contains, so old records are deleted ("scrolled out" of trace detail tree 350 will be that of the data to which the 

the display). The rows counter at the top of the trace tree pointer points. However, for pointer fields that reside within 

pane 310 indicates the number of records in the trace buffer 20 arguments, only the address contained in the pointer will be 

105 and the number of rows in the trace tree. Because the displayed. In other words, in the preferred embodiment, the 

buffer 105 is circular, the number of rows in the trace tree pointer is de-referenced only for the first level arguments. 

330 continuously grows during the beginning of the tracing One skilled in the art will understand that other pointers 

process until the buffer wraps (typically 20,000 to 40,000 could be de-referenced as well, and that the trace detail tree 

records). Thereafter, the number remains approximately at 25 350 could display the value pointed to by arguments deeper 

the same level as old records are overwritten with new than the first level. 

records. The exact number of records that are kept in the In one embodiment, the trace detail pane 316 also shows 

trace buffer 105 depends on the size of the trace records. The time stamps. The time stamps display the time that a 

size of each trace record is determined by the TCI options function is called and the time that the function returns to its 

specified by the developer 112. For example, if the devel- 30 caller. 

oper 112 requires tracing of "this" class members, the size If the argument is an array of known size, then the 

of the records will increase and the number of records in the elements of the array will be displayed. If the array size is 

buffer will decrease. unknown, then the value displayed is the value of the first 

The analyzer 106 and the agent 104 can trace a multi- array element. If the argument is of character pointer type, 

threaded and multi-processed client 102. When tracing a 35 then the string value is displayed. If the argument is numeric, 

multi-threaded process, different threads are separated from then the decimal, hex, or decimal and hex values are 

each other in the trace tree pane 310 by a thread caption bar displayed, depending on the selection made in the advanced 

320. For multi-process applications, similar horizontal bars, trace options. Right-clicking the mouse when it points in the 

called process caption bars (not shown), separate trace lines trace detail pane 316 displays a popup menu which allows 

belonging to different processes. The thread caption bar 320 40 the developer 112 to select how numeric arguments are 

and the process caption bar separate the trace tree 330 into displayed (as decimal, hex, or decimal and hex values), 

sections. These caption bars represent a context switch in the The source pane 318 shows the source code for the 

application, between threads and between processes. Pro- selected function or source line selected in the trace tree 330. 

cess caption bars are similar to the thread caption bar 320, The source code listed in the source pane 318 is automati- 

therefore any future mention of threads also applies to 45 cally scrolled to the location of the selected object, if 

processes in multi-process applications. possible. The line in the source code is displayed in bold and 

The thread caption bar 320 contains a name field, a is pointed to by an arrow. The analyzer 106 looks for the 

process ID number field, and a thread ID number field 321, source file in the current directory and in the directory 

Within the trace tree 330 itself, there is an up arrow at the indicated in the .PDB file. If the source file is not found, the 

top of each section, and a down arrow at the bottom of each 50 source pane remains blank. In this case, the developer 112 

section. Clicking the up arrow causes the displayed trace tree can change the source file search path in order to display the 

330 to jump to the previous point in the trace tree 330 where source code. To change the source file path the developer 

the thread gained control. Clicking the down arrow causes should select a function in the trace tree 330, then right-click 

the displayed trace tree 330 to jump to the next point in the in the source pane to open a pop-up menu, and then select 

trace tree 330 where the thread gains control. The trace tree 55 the "Source Location" from the pop-up menu. Alternatively, 

330 also provides an expand/collapse control button 326 to the developer 112 can add additional source directories and 

allow the developer 112 to expand and collapse the current remove source directories by selecting the "Options" com- 

thread view. The trace tree pane 310 also provides a vertical mand from the "View" menu on the menu bar 304. Source 

scroll bar for scrolling up and down through the trace tree file paths can also be removed. 

330. When the trace tree pane 310 is scrolled up or down to 60 The analyzer 106 provides several features which make it 

a section containing functions of lower hierarchical levels, easier to analyze trace information and pinpoint a bug in the 

the portion of the trace tree 330 displayed in the window is client 102. These features can be used both while performing 

shifted leftwards. The depth of this shift, with respect to the an online trace and while viewing trace information from a 

first function called in the process, is indicated by a stack remote log file 122. Analysis features include: saving trace 

level indicator 328 appearing in a rectangle in the upper left 65 information to a log file 122; printing the trace tree 350; 

corner under the thread caption bar 320 (as shown in FIG. searching for trace elements; locating a function in the trace 

3). options window 500; filtering the trace information; adding, 
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editing, deleting and locating bookmarks; clearing the trace Internal Implementation Details of the BugTrapper System 
tree pane; and displaying multiple windows. Additional The sections that follow discuss various internal opera- 
features available for online tracing include saving trace tional and implementation details of the agent 104, the 
information to the log file 122. analyzer 106, the trace libraries 124, 125, and how these 
The "Find" button on the toolbar 306 is used to initiate a s elements interact with the client 102 and the operating 
search for an element in the trace tree 330. Clicking the Find system, 
button opens a "Find what" dialog box in which the devel- The Attaching Mechanism 

oper 112 can enter a search text string. The find what dialog One aspect of the present invention is the attaching 
provides a "Find Next" button to start a search for the mechanism used by the BugTrapper to collect trace infor- 
occurrence of the specified search text. The first occurrence 10 mation. With traditional tools, it was necessary to manually 
of the specified text is highlighted in the relevant pane. enter trace points in the application's source code, or at a 
Functions in the source code displayed in source pane 318 minimum, even if trace points were automatically added to 
can be located in the trace options dialog 500 by right- the source, to re-compile the source code. With BugTrapper, 
clicking inside the source code in the source pane 318. The tracing is accomplished by attaching to the memory image 
right-click opens a pop -up menu. The developer then selects 15 of the application (i.e., the copy of the executable code that 
a "Locate in Trace Options" command from the pop-up is loaded into RAM or other memory for execution). There 
menu to open the trace options window 500. The trace is no need to enter trace points into, or to otherwise modify, 
options window 500 will open with the desired function the source, object, or executable files of the client 102 
displayed and highlighted. application. No special tracing version of the client 102 is 
The trace filter previously described in the text relating to 20 needed, and the client 102 need not be written in any special 
FIG. 5 is a tool that enables the developer 112 to select the manner. Attaching to the client 102 in memory allows 
functions to trace. When using the trace filter to change the function calls, returns, and other source lines to be traced, 
display while performing an online trace, the trace continues The attaching mechanism also allows for the tracing of any 
in the background, and when the developer 112 closes the executable, including optimized (release) builds, multi- 
trace options window 500 the new filter is applied to the 25 threading and multi-processes, longjumps, signals, 
display in the trace window 300. The developer 112 can also exceptions, and recursions. 

use the trace options window 500 to change the display The BugTrapper client-side trace library 125 is attached to 

while performing an off-line trace. This enables the devel- the client 102, in part, by modifying certain executable 

oper 112 to filter out traced elements and display a subset of instructions of the memory image of the client 102. This 

the traced information. The information contained in the log 30 process is generally called "executable code 

file is not modified, only the display changes. instrumentation/' or simply "instrumentation." The instru- 

A bookmark allows the developer 112 to mark trace lines mentation process is performed such that the functionality of 

(functions or source lines) in the trace tree 330. The devel- the client 102 is preserved. Because the instrumentation is 

oper 112 can also edit the name of a bookmark or delete the made only on the memory image, there is no need to 

bookmark it as required. Bookmarks are inserted in the trace 35 pre-process or modify the source code or executable files of 

tree 330 by using the bookmark button on the toolbar 306. the client 102. Use of the client-side trace library 125 

Bookmarks allow easy jumps to the bookmarked element. provides significant advantages over the prior art by elimi- 

To insert a bookmark in the trace tree 330, the developer nating the need for context switches when debugging a 

will: select the trace line (a function or source line in the program. Context switching has the effect of significantly 

trace tree 330) to mark; press the bookmark button to open 40 slowing down the rate of execution. The tracing implemen- 

the bookmark window; type the bookmark name in the tation provided by BugTrapper can therefore be used to 

bookmark widow; and click the OK button. A waiving flag study the real time behavior of a program and detect bugs 

icon 332 appears on the left of the bookmarked trace line in resulting from such behavior. Although one skilled in the art 

the trace tree 330. The bookmark name is displayed when- will recognize that the present invention can advantageously 

ever the cursor is placed over the bookmarked line. To 45 be used with any operating system, a preferred embodiment 

change a bookmark name, the developer 112 repeats the runs under the Windows-NT and Windows-95 operating 

steps to create a bookmark. To delete a bookmark from the systems supplied by Microsoft Inc. The following descrip- 

trace tree 300, the developer 112 can press a delete button on tion of the internal details of the BugTrapper will thus be 

the bookmark window. The "Goto Bookmark" command described in terms of the Windows-NT/95 operating systems 

from the "Edit" menu is used to go to a bookmark in the 50 with the understanding that the invention is not limited to 

trace tree 330. said systems. 

Multiple instances of the analyzer 106 can be open The trace libraries 124, 125 include a number of callable 

simultaneously. Each instance can define different filter functions (discussed below). By using the callable functions, 

options for each window. This feature is especially useful for and system functions provided by the Win32 API 

multi -threaded applications, where it is convenient to 55 (application program interface), the trace libraries performs 

observe each thread in a separate window. two major tasks: (1) attaching specialty functions to 

The analyzer 106 provides for starting and stopping of an application, and (2) tracing the execution of the applica- 

online trace. All trace points are disabled when tracing is tion's executable code. Both of these tasks are described 

stopped. Stop is helpful if the trace adversely influences the separately below. The agent-side trace library 124 is prima- 

application performance and it appears that the subsequent 60 rily responsible for attaching the client-side trace library 125 

operations in the client 102 are not relevant to the problem to the client 102. The agent-side trace library 124 also 

being analyzed. The Start/Stop Tracing button on the toolbar provides communication with the client -side library 125. 

306 is used to toggle tracing on and off. Tracing is stopped The client-side trace library 125 is primarily responsible for 

or restarted as specified. When tracing is stopped, the placing data in the trace buffer 105. In the following 

boundaries of the lost tree portion appear in the trace tree 65 description, the term "client process" is used to refer to the 

pane 330 as a tear 1202, as shown in FIG. 12. When tracing executable code of the client 102 that has been loaded into 

is resumed, the trace tree 330 continues under the tear 1202. a memory space for execution. BugTrapper refers both to 
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BugTrapper Agent or BugTrapper Analyzer, depending Creation Attach is accomplished under Windows- NT by 

whether it is operating in the Online mode or the Remote creating the client process in a suspended state, by using the 

mode. CREATE_SUSPENDED flag in the CreateProcess( ) func- 

The act of attaching to a currently running process is tion. In this case, the previously described procedure cannot 

known as a Process Attach. The act of attaching to a new 5 be used, since none of the system DLLs in the client process 

process, during the creation of the new process, in order to have been initialized. In particular, since KERNEL32.DLL 

trace the new process from its start is known as a Creation is not loaded, the client-side trace library 125 cannot be 

Attach. In a Creation Attach it is desirable to pause the client loaded. The present attaching procedure overcomes this 

102 process as close as possible to its entry point so that difficulty by performing the following attaching procedure, 

virtually all of the functions executed by the client 102 will io which begins at a procedure block 1402 shown in FIG. 14. 

be traced. To attach to a new client 102, the attaching procedure 

In the Windows-NT and Windows-95 operating systems, begins in block 1402, in which the client process is created 

each process resides at a distinct location or "address space"' in a CREATE_SUSPENDED state. The attaching proce- 

in memory. A DLL> such as the client-side trace library 125, dure then advances to a procedure block 1404. In the 

which resides in another address space, cannot simply be 15 procedure block 1404, BugTrapper makes a call to the 

loaded into the same address space as the client process. To inst_prepare( ) of the agent-side trace library 124. The 

overcome this limitation, BugTrapper forces the client pro- inst_prepare function, using WriteProcessMemory( ) and 

cess to load the client-side trace library 125 DLL (using a Virtu alAllocEx( ), allocates memory in the client process 

process called injection) into the process space of the client and copies a small assembly language code segment into the 

process. 20 allocated space. The procedure then proceeds to a procedure 

Attaching to a Client Running Under Windows-NT block 1406 where the inst__prepare function overwrites the 

In a preferred embodiment, the injection process for entry point of the client executable in the client process with 

Process Attach in Windows-NT is accomplished by using a jump instruction to the new assembly code. The attaching 

the CreateRemoteThread( ) function of the Win32 API, to procedure then advances to a procedure block 1408 wherein 

create a remote thread in the client process and to force the 25 the inst_prepare function allows the client process to 

newly created thread to run code in the client process. The resume, and thereby start the initialization process for the 

code that is run by the remote thread is a copy of an injection client process. After all DLLs are initialized, including the 

function copied to the remote thread using the Win32 API client-side trace library 125, execution continues to the entry 

WriteProcessMemory( ) function. The Process Attach point of the client executable, which now contains a jump to 

involves the following sequence of events shown in FIG, 13 30 the new assembly code. When the jump occurs, the attaching 

beginning with a procedure block 1302 where the function procedure advances from the procedure block 1408 to a 

inst_attache of the tracing library is called in BugTrapper, procedure block 1410. In the procedure block 1410, the 

using the process ID ("PID") of the client (client) process as assembly code restores the original client entry point, and 

an argument. The function inst_attach( ) performs the suspends the client process. At this point, the client process 

following operations: 35 is suspended without running any executable code, but is 

1) It obtains a handle to the client process using past the initialization stage. The attaching procedure then 
OpenProcess( ); advances to a procedure block 1412. 

2) It allocates memory in the client process's address In the procedure block 1412, BugTrapper can now call 
space using the Win32 API function VirtualAllocEx( ); inst__attach( ) to attach to the client process and start 

3) It copies the code for the injection function and other 40 instrumenting it. When the attaching procedure is complete, 
various data (including the full path of the Trace Library) it can allow the client process to resume. The assembly code 
onto the allocated memory space using the simply jumps directly back to the original entry point of the 
WriteProcessMemory( ) function; and client 102, and execution of the client 102 starts with the 

4) It creates a new thread in the client process with proper instrumentation. 
CreateRemoteThread( ). 45 Attaching to a Client Running Under Windows-95 

The new thread created in step 4 starts executing at the In Windows-95, Process Attach and Creation Attach are 

address to which the injection function was previously implemented in a manner different from the Windows-NT 

copied in step 3. The procedure then advances from the manner discussed above because the CreateRemoteThread 

procedure block 1302 to a procedure block 1304 where the API call is not supported in this operating system, 

injection function starts running in the new thread of the 50 Creation Attach under Windows-95 exploits the fact that 

client process. Using data passed to it via other parts of the process initialization starts from a known entry point of 

memory space, the injection function loads the client-side kernel32.dll. BugTrapper creates the client process in the 

trace library 125. suspended mode and then calls to the inst95__attach func- 

The procedure advances from the procedure block 1304 to tion. This function performs the following sequence of 

a procedure block 1306 where the client-side trace library 55 operations: 

125 runs in the context of the new thread while the instru- i) i t initializes the communication channel for IPC with 

mentation is taking place. The client-side trace library 125 the client process. 

communicates with BugTrapper (i.e., the agent-side trace 2) ft ks vafious daU (such as the In j ection Function 

library 124), handling commands, and actually performing ^ and th& path for tfae clienl _ side trace library ^5) 

the instrumentation. 60 ^to ^ client > s address space, using WriteProcess- 

The procedure advances from the procedure block 1306 to Memory function 

a procedure block 1308 where the client-side trace library _ Ti . . . 

125 exits, and the injection function destroys its own thread 3 > 11 imtiahzes a shared hea P meraor y- 

and stops executing by calling the ExitThread( ) function. 4) It copies onto the heap a small piece of assembler code 

Unlike other debuggers that terminate the debugged process 65 (a patch) that executes the jump to the function that 

on exit, here the client 102 continues to run, without any creates thread in the client process 

substantial alteration to the functionality of the client 102. 5) It copies the injection function itself 
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6) It patches the entry point of kernel32.dll so that the 
entry point points to the shared heap address where the 
assembler code is located. Because of the lack of "Copy 
on Write*' mechanism in Windows-95, this patching 
applies also to the client process. 

7) It resumes the main thread of the client process. 

8) In the client process, the entry point of kernel32.dll is 
called and, thus, the applied patch starts execution. The 
patch performs the following operations: 

a) The patch removes the patch applied on the 
kemel32.dll entry point and restores the original 
kemel32.dll code. 

b) The patch creates a new thread, which runs the 
injection function. 

c) The injection function loads the client-side trace 
library 125. 

d) The injection function initializes the client-side trace 
library 125 and the communication channel in the 
client process so that the two trace libraries 124, 125 
can communicate. 

9) If inst95_attach returns successfully, then the initial 
instrumentation of the client process is done and the 
tracing begins. 

During a Process Attach, BugTrapper calls the inst95_ 
attach to running process function in the agent-side trace 
library 124. The inst95_attach_to_nmning_process func- 
tion executes the following sequence of operations: 

1) It initializes the communication channel for IPC with 
a client process 

2) It calls a function create_remote thread (not to be 

confused with the CreateRemote Thread API call in 
Windows-NT), that performs the following operations: 

a) It allocates memory on the shared heap. 

b) It copies various data (such as the Injection Function 
code and the path for the client-side trace library 
125) onto the heap 

c) It finds a valid thread handle from the client process. 

d) It suspends the valid thread 

e) It sets the single step flag in the valid thread context 

f) It releases the valid thread 

A device driver, which will be further described below, 
intercepts the INT 1 interrupt that is caused by the first 
executed instruction of the above mentioned valid thread. 
Upon receiving the interrupt, the device driver sets the 
instruction pointer to the start address of the injection 
function that was copied onto the shared heap, and clears the 
single step flag in the valid thread context. After clearing the 
single step flag, the driver proceeds as if the interrupt was 
successfully handled, and returns the control to Windows- 
95. 

Since the instruction pointer now points to the injection 
function, the injection function starts to execute in the 
context of the client process. The injection function contin- 
ues as in the case of Creation Attach described above and 
creates a new thread that subsequently performs the loading 
of the client-side trace library 125 into the address space of 
the client 102. 

In order to leave the interrupted valid thread intact, the 
injection function executes the breakpoint instruction, which 
immediately causes an INT 3 interrupt that is intercepted by 
the device driver. The device driver restores the thread 
context that was stored immediately after the thread was 
suspended and then the device driver returns the control to 
Windows-95. 

Tracing execution 

The trace function involves tracing the execution of the 
instrumented client process and reporting certain events to 



BugTrapper. The client-side trace library 125 accomplishes 
the tracing function by using breakpoints, and by reporting 
information concerning the status of the client process upon 
reaching the breakpoints. 

5 During the execution of the client process, the execution 
trace is stored within a fixed size circular trace buffer 105 in 
memory. In the remote mode of operation the contents of the 
trace buffer 105 are copied to a trace log file 122. The trace 
log file 122 thus contains trace information that reflects a 

10 time window ending with the writing of the log file 122, The 
length of this time window is generally dependent upon the 
size of the trace buffer 105. In a preferred embodiment, the 
trace buffer 105 is small enough to allow the trace log file 
122 to be sent to the developer's site using standard email 

15 programs. In the online mode of operation, the display is 
constantly being updated mirroring the trace buffer 105. The 
displayed information can also be saved to a log file 122 and 
later re-displayed. 

After the client process has been attached, the process of 

20 tracing the execution of the client 102 involves the steps of 
installing breakpoints, triggering breakpoints, and catching 
breakpoints. Breakpoints are installed by overwriting the 
target address of the assembly instruction to be traced with 
an INT 3 instruction, occupying a single byte of space. The 

25 original byte at that address, along with other information, is 
stored in a data structure created by the agent-side trace 
library 124. The data structure, which describes all trace 
points, is preferably a hash table comprising a corresponding 
array of records for each hash value. The hashing is imple- 

30 mented with the target address as a parameter, allowing for 
a very fast searching for information concerning a trace 
point by using its address. 

Breakpoints are triggered whenever the target address 
gets executed. When the target address is executed, the 

35 breakpoint instruction generates an INT 3 interrupt. On 
Windows NT this interrupt is handled by the Windows-NT 
kernel-mode handler. The kernel-mode handler transfers the 
execution to the user-mode routine KiUserExceptionDis- 
patcher inside NTDLL.DLL (the system DLL). The KiUser- 

40 ExceptionDispatcher routine handles the task of locating a 
corresponding exception filter for the particular kind of 
exception. 

Catching of breakpoints occurs within the context of the 
client 102. With standard debuggers, control would pass to 
45 the debugger process at this point. BugTrapper, takes a new 
approach, eliminating the need for context switching to 
properly trace the execution (for better performance). Since 
no context switching takes place, control remains with the 
client 102. 

50 When the client-side trace library 125 is initially loaded, 
a patch is applied to the KiUserExceptionDispatcher 
function, having the effect of forcing a call to a function in 
the client-side trace library 125 before processing the excep- 
tion. This function (the BugTrapper exception handler), 

55 determines whether the breakpoint occurred as a result of the 
tracing or for another reason. An exception that is not the 
result of tracing (i.e., no trace point has been installed at this 
target address) will result in a return of execution to KiUser- 
ExceptionDispatcher. When an exception is the result of the 

60 tracing, the handler notifies the appropriate routines in the 
tracing library 125 and defers the breakpoint, thereby allow- 
ing the original instruction at the target address to execute. 

To defer a breakpoint, the original byte at the target 
address is restored, returning execution while setting the 

65 Single Step flag in the FLAGS register of the x86 processor. 
The Single Step flag causes an INT 1 interrupt to occur as 
a result of the execution of the original instruction. This 
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interrupt is also treated as an exception, eventually reflecting 
into the BugTrapper exception handler. The handler restores 
the breakpoint instruction at the target address and returns 
for second time, allowing the client process code to continue 
running as if nothing happened. 

In Windows 95, interception of the INT3 and INT1 
interrupts is done by a device driver. The driver registers its 
interrupt handler for INT1 and INT3 interrupts. When the 
interrupt handler is called, it checks to see if the interrupt 
occurred in the context of the client process. If the interrupt 
occurred in the client process, then the interrupt handler 
changes the instruction pointer of the thread to the address 
of a function in the client-side trace library 125, and passes 
back on its stack any data needed by the function (such as 
thread context). After this function handles the trace point, 
it triggers an additional INT 3 interrupt that is recognized by 
the device driver. The device driver acts as if the interrupt 
has been successfully handled, causing the traced thread to 
continue execution. When the device driver recognizes that 
an interrupt has occurred not in the context of the client 
process, then the device driver passes the interrupt to the 
operating system interrupt handler (thus not affecting the 
normal behavior of other programs in the system or the 
operating system itself). 

When tracing a plain source line (e.g., not a function entry 25 
or exit point), the client-side trace library 125 inserts data in 
the trace buffer to indicate that a trace point has been 
reached. When reaching a function entry trace point (apart 
from writing data to the trace buffer) a special mechanism is 
used because tracing of information regarding both the entry 
to and exit from the function is desired. This is preferably 
accomplished by modifying the return address of the func- 
tion. The return address is located on the stack. The original 
return address is saved and a new return address point is 
inserted. The new return address points to a special assembly 
stub inside the client-side trace library 125. Therefore, when 
the function returns the assembly stub is called. The stub 
reports to the client-side trace library 125 function that the 
function has exited, and the client-side trace library 125 
writes this trace point to the trace buffer. The stub then jumps 40 
to the real return address of the function. 

In certain environments it is possible for a function to be 
entered but not properly exited. The function ceases running 
(with its stack erased and execution continuing elsewhere), 
but never returns to its caller. Therefore, for tracing 45 
purposes, it never returned to the BugTrapper assembly stub. 
For example, this would happen when a C++ exception 
occurs inside the a function and the exception handler at an 
outer function instructs the function generating the excep- 
tion to exit, or when the setjmp( )/longjmp( ) functions are 50 
used in C/C++ programs. To detect and trace such events, the 
microprocessor's stack pointer register (ESP) is checked 
whenever a trace point triggers to determine whether any 
functions have exited. The stack pointer normally grows 
down. Its position is registered at the entry of each function 55 
together with the above-mentioned return address. If the 
stack pointer has moved to a higher point than that at entry, 
the function is deemed to have exited, and the client-side 
trace library 125 reports that the function has exited. Several 
different redundant checks are also performed to ensure the 60 
reliability of this mechanism. 
Additional Tracing and Attaching Features 

The BugTrapper attaching technology can be used with 
multi-process and multi-threaded applications. Every trace 
record is associated with a process and a thread. Stack 65 
information is separately kept for each context. Therefore, 
the BugTrapper can trace two or more client executables at 
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the same time. This allows BugTrapper to display any 
context switches between the processes and threads of the 
client(s) 102. 

The BugTrapper supports the tracing of Dynamically 
Linked Libraries (DLLs), including all sub-formats such as 
OCX, Active-X, drivers (DRV), etc. The tracing of DLLs is 
accomplished by analyzing the client 102 process to find the 
DLLs it uses, and by displaying the source structures of the 
DLLs to the user. The user can then specify trace points 
within the DLLs as is done for any other executable. When 
applying trace points to a DLL, BugTrapper finds the base 
address into which the DLL was loaded, and uses the address 
to translate the addresses in the debug information to actual 
addresses in the running image. 

The BugTrapper also supports the tracing of DLLs for 
which no debug information is available, such as system 
DLL's. The tracing of such DLLs is accomplished by 
tracking the exported functions used by the DLLs. This is 
done by analyzing the DLL exported function table in the 
client 102 to retrieve information concerning the exported 
function names and addresses. If the types of the parameters 
passed to these functions are known (e.g., if the header file 
including the declarations of the functions is available), then 
the parameter values and return value are also logged. 

The BugTrapper also supports tracing of sub-processes. 
For example, when a first process PI and a second process 
P2 are listed in the executable pane 314, and PI spawns P2 
as a sub-process, then BugTrapper will start tracing P2. This 
is done by tracing the CreateProcess function in all of the 
traced processes, even if the developer 112 did not specify 
tracing the CreateProcess function. By tracing 
CreateProcess, BugTrapper will know that PI is going to 
spawn a sub-process, and BugTrapper can identify that the 
sub -process name (P2 in the present example) is listed in the 
executable pane 314. the client-side trace library will then 
create the sub -process and attach to the sub-process using 
the "Creation Attach" mechanism discussed above. 

Variables and memory values can also be traced by 
BugTrapper. The user can view variable values as in an 
ordinary debugger. The variables may include function 
arguments, the C++ "this" pointer, function return values, 
local variables, global variables, static variables, etc. The 
data to which a pointer is pointing can also be traced. This 
information can be viewed for optimized builds, which 
cannot always be done by current debuggers. Tracking of 
variables in memory is accomplished by first analyzing the 
debug information to find the address (global, static, stack, 
or dynamic address) of the variable and the data it holds. 
BugTrapper then uses these addresses to dump to the trace 
log file 122 the memory content according to variable size. 

When the traced application crashes, BugTrapper records 
the point where the failure occurred, even if the line was not 
specified in the TCI file 120. All stack variables are saved by 
using the Win32 debug API and the system library IMAGE- 
HLP.DLL. 

Interprocess Communication 

Communication between the client-side trace library 125 
and the agent-side trace library 124 (in the agent 104 or the 
analyzer 106) can be divided into two categories. Category 
one comprises normal messages. Category two comprises 
trace data. 

Category one communication is accomplished using stan- 
dard Windows InterProcess Communication (IPC) 
primitives, such as shared memory to pass data, and sema- 
phores to signal and synchronize. Normal messages include 
commands sent to the client-side trace library 125 such as, 
start trace function at a given address, or suspend tracing. 
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Normal messages also include notifications sent by the 
client-side trace library 125, such as creation of a sub- 
process or run-time loading of a DLL. 

The trace data itself is sent using a different mechanism, 
because of the quantity of data. Trace data comprises: 
function calls (including the assembly address of the called 
function); values of parameters for each call; function return 
values (including function address); tracing of other source 
lines specified in the TCI file 120 (including their address); 
variables value at these addresses; etc. The trace records are 
written to a shared memory area called the trace buffer 105, 
and from there either displayed in the BugTrapper user 
interface by the analyzer 106 (when performing an online 
trace) or written to a log file by the agent 104 (when 
performing a remote trace). 

The client-side trace library 125 running in context of the 
various traced threads and processes, and the agent-side 
trace library 124, prevent simultaneous access to the trace 
buffer using a standard locking mechanism such as Mutex 
(in Windows-95) or Interlocked Functions (in Windows- 
NT). For performance reasons, when collecting trace data, 
the client-side trace library 125 preferably only writes trace 
data to the trace buffer 125 in shared memory. The client- 
side trace library 125 preferably performs no I/O to the disk 
or to the display. Disk I/O and display updates are done later 
by the agent 104 or the analyzer 106. This reduces the 
performance penalty imposed on the client 102. 

Indexing of the Trace Data 

In order to process scrolling of the trace tree efficiently, 
there should desirably be direct access to records in the trace 
buffer 105 or trace log file 122. Serial access would be 
inefficient because it would require a search for the needed 
data in the trace buffer 125 upon every tree scroll operation. 
To facilitate direct access, an index is maintained with every 
trace tree window. The index contains the locations of all of 
the "function call" records in the trace buffer, which are 
included in the filter of the corresponding window in which 
the trace tree is displayed. In addition to the location 
information, some user-interface related information such as 
whether the record is invisible ("collapsed") is kept. The 
developer 112 can "collapse" (remove from display) part of 
a tree which is located under a specific call in the tree 
hierarchy. Collapsing part of a tree influences the current 
displayed portion of the tree. 

For example, assuming that only one record is displayed 
on a tree having a scroll bar, if the tree includes records (1 
2 3 4 5) and the scroll bar is located at the middle, record 3 
should be displayed. However, if records 2 and 3 are 
collapsed (leaving 1 4 5), then record 4 should be displayed. 
For a tree including more than a million lines, including 
thousands of collapsed records, the calculation of the loca- 
tion of the displayed portion of the trace data might be a 
time-consuming task. In order to do this efficiently, the 
analyzer 106 holds, together with the above-mentioned calls 
index, a special array SA, where SA[i] contains the number 
of visible records from record number 1000*i to 1000*(i+l). 
Use of the SA array greatly speeds up the task of locating 
desired trace information. For example, assume that records 
500-550 are invisible (collapsed by the developer 112) and 
that the vertical scroll bar position is 1500. In this case 
SA[0]=950 and the appropriate record is 1550. The analyzer 
106 calculates this number directly, without the need to scan 
the whole calls index: 1000-SA[0]+1500(scroll bar 
position^lSSO. The SA array provides for very fast vertical 
scrolling. The SA array is updated each time a new record is 
read from the trace buffer 105 or the log file 122, or when 
the developer 112 collapses or expands some of the trace 
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tree. In general, when the analyzer 106 draws a trace tree, it 
performs the following steps: (1) lock the trace buffer 105; 
(2) scan new records and update the calls index and the SA 
array; (3) read and analyze the records that must be shown; 
(4) merge the records with the debug information 121 and 
create strings for each record; (5) draw the page; and (6) 
unlock the shared memory trace buffer 105. Note that when 
reading data from a trace log file 122 only steps 3-5 are 
performed, since steps 1, 2, and 6 are unnecessary. 
Other Embodiments 

Although the present invention has been described with 
reference to a specific embodiment, other embodiments will 
occur to those skilled in the art. It is to be understood that 
the embodiment described above has been presented by way 
of example, and not limitation, and that the invention is 
defined by the appended claims. 

What is claimed is: 

1. A software system that facilitates the process of iden- 
tifying and isolating bugs within a plurality of programs 
each running one or more threads, without requiring modi- 
fications to executable or source code files of said programs, 
each of said programs including at least a source code 
representation, an executable code representation, and build 
information that links the source code representation to the 
executable code representation, the build information gen- 
erated during building of the executable representation from 
the source code representation, the software system com- 
prising: 

a first user interface module that displays source code 
elements of one or more source programs on a display 
screen together with controls that enable a software 
developer to interactively specify one or more source 
code elements to be traced, the first user interface 
module configured to generate trace control informa- 
tion based on selections by said developer of said 
source code elements to be traced, said first user 
interface module using at least said build information to 
generate said trace control information; 

a first library module configured to attach to a memory 
image of a first process executing a first program, said 
first library module configured to use said trace control 
information to monitor execution of said first program 
and to generate first trace information; 

a second library module configured to attach to a memory 
image of a second process executing a second program, 
said second library module configured to use said trace 
control information and to monitor execution of said 
second program and to generate second trace informa- 
tion; and 

a second user interface module that translates said first 
and second trace information into a human-readable 
form based at least on said build information, and 
displays translated information on a display screen to 
allow said developer to analyze the execution of said 
first and second programs. 

2. The software system of claim 1, wherein said first and 
second library modules are adapted to be executed sepa- 
rately from said first and second user interface modules, the 
system thereby enabling a developer to remotely control and 
evaluate the tracing of said first and second programs. 

3. A software execution tracing system loaded into a 
computer memory for tracing a plurality of concurrently 
running client programs, each of said currendy running 
client programs having at least a source code representation 
and an executable code representation, said software system 
comprising: 

a first trace library module that attaches at runtime to a 
memory image of a first running program, said first 
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running program being one of said client programs, 
said first trace library module configured to monitor 
execution of said first running program and to generate 
first trace information that reflects execution of said 
first running program; and 
a second trace library module that attaches at runtime to 
a memory image of a second running program, said 
second running program being one of said client 
programs, said second trace library module configured 
to monitor execution of said second running program 
and to generate second trace information that reflects 
execution of said second running program. 

4. The software system of claim 3, wherein said first and 
second trace library modules are configured to run under the 
control of a multi-processing operating system wherein said 
first and second running programs are running concurrently. 

5. The software system of claim 4, wherein said first and 
second trace library modules are configured to run under the 
control of an operating system wherein said first and second 
running programs are multithreaded. 

6. The software system of claim 3, wherein said first and 
second trace library modules are configured to generate trace 
information according to trace control information. 

7. The software system of claim 3, wherein said first trace 
library module and said second trace library module are 
configured to run at the same time on a multi-processor 
computer system. 

8. The software system of claim 3, further comprising a 
display module configured to display at least a part of said 
first and second trace information. 

9. The software system of claim 8, wherein said display 
module displays translated trace information on a display 
screen during execution of at least one of said first and 
second running programs. 

10. The software system of claim 8, wherein said display 
module provides an offline analysis mode which provides 
functionality for interactively analyzing translated trace 
information after the monitoring of at least one of said first 
and second running programs has completed. 

11. The software system of claim 8, wherein said display 
module is configured to translate at least part of said first 
trace information into a human- readable form based on at 
least build information. 

12. The software system of claim 11, wherein said build 
information comprises debug information generated by a 
compiler program during compilation of said first client 
source code representation. 

13. The software system of claim 8, wherein said display 
module is configured to display process information. 

14. The software system of claim 8, wherein said display 
module is configured to display information showing when 
said first running program is executing in relation to when 
said second running program is executing. 

15. The software system of claim 8, wherein said display 
module is configured to show a temporal relationship 
between execution of said first running program and said 
second running program. 

16. A software execution tracing system loaded into a 
computer memory for tracing a plurality of concurrently 
running client programs, each of said currently running 
client programs having at least a source code representation 
and an executable code representation, said software system 
comprising: 

a first trace library module that attaches during runtime to 
a memory image of a first running program, said first 
running program being one of said client programs, 
said first trace library module configured to monitor 
execution of said first running program and to generate 
first trace information that reflects execution of said 
first running program; and 
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a second trace library module that attaches during runtime 
to a memory image of a second running program, said 
second running program being one of said client 
programs, said second trace library module configured 

5 to monitor execution of said second running program 
and to generate second trace information that reflects 
execution of said second running program wherein said 
first and second trace library modules are configured to 
run under the control of a multi-processing operating 
system, said first trace library module configured to run 

10 in a process memory space that has been allocated to 
said first running program and said second trace library 
module configured to run in a process memory space 
that has been allocated to said second running program. 

17. A method for simultaneously tracing the execution 
path of first and second client programs, said first client 

15 program having a first memory image and said second client 
program having a second memory image, the method com- 
prising the steps of: 

instrumenting said first memory image at runtime to 
enable execution of said first client program to be 
20 traced; 

instrumenting said second memory image at runtime to 
enable execution of said second client program to be 
traced; and 

collecting trace data relating to a concurrent execution of 
25 said first client program and said second client pro- 
gram. 

18. The method of claim 17, wherein said concurrent 
execution comprises time -shared execution of said first 
cHent program and said second client program. 

30 19. The method of claim 17, wherein said concurrent 
execution comprises parallel execution of said first client 
program and said second client program on a multi- 
processor computer system. 

20. The method of claim 17, wherein said second client 
35 program is executed in a sub-process of said first client 

program. 

21. The method of claim 17, wherein said first client 
program is a dynamic link library. 

22. The method of claim 17, wherein said first memory 
image and said second memory image are in separate 

40 address spaces. 

23. The method of claim 17, wherein said trace data is 
stored in shared memory. 

24. The method of claim 17, wherein said step of instru- 
menting said first memory image comprises attaching a trace 

45 library module to said first memory image. 

25. The method of claim 17, further comprising the step 
of analyzing said trace data. 

26. The method of claim 25, wherein said step of ana- 
lyzing comprises translating said trace information into a 

50 human-readable form. 

27. The method of claim 25, wherein said step of ana- 
lyzing comprises translating said trace data into human- 
readable data based on at least build information, 

28. The method of claim 25, wherein said step of ana- 
55 lyzing comprises displaying an execution call tree display. 

29. The method of claim 28, wherein said execution call 
tree display shows a first execution call tree for said first 
cheat program and a second execution call tree for said 
second client program. 

30. The method of claim 28, wherein said execution call 
60 tree display shows a temporal relationship between execu- 
tion of said first client program and said second client 
program. 

31. The method of claim 28, wherein said execution call 
tree display shows execution call trees for a plurality of 

65 threads. 

* + * * * 
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